﻿@{
    ViewBag.Title = "Index";
    Layout = "~/Views/Shared/_Index.cshtml";
}
<div class="layuimini-container">
    <div class="layuimini-main">
        <fieldset class="table-search-fieldset layui-hide" id="searchField">
            <div>
                <form class="layui-form layui-form-pane">
                    <div class="layui-form-item">
                        <div class="layui-inline">
                            <label class="layui-form-label">关键字:</label>
                            <div class="layui-input-inline">
                                <input type="text" id="txt_keyword" name="txt_keyword" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-inline">
                            <button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="data-search-btn"><i class="layui-icon">&#xe615;</i> 搜 索</button>
                        </div>
                    </div>
                </form>
            </div>
        </fieldset>
        <script type="text/html" id="toolbarDemo">
            <div class="layui-btn-container" id="toolbar">
                <button id="NF-add" name="NF-add" authorize class="layui-btn layui-btn-sm data-add-btn" lay-event="add"><i class="layui-icon">&#xe654;</i>新增</button>
                <button id="NF-edit" name="NF-edit" authorize class="layui-btn layui-btn-sm layui-btn-warm data-edit-btn layui-hide" lay-event="edit"><i class="layui-icon">&#xe642;</i>修改</button>
                <button id="NF-delete" name="NF-delete" authorize class="layui-btn layui-btn-sm layui-btn-danger data-delete-btn layui-hide" lay-event="delete"> <i class="layui-icon">&#xe640;</i>删除</button>
                <button id="NF-details" name="NF-details" authorize class="layui-btn layui-btn-sm layui-btn-normal data-info-btn layui-hide" lay-event="details"> <i class="layui-icon">&#xe60b;</i>记录</button>
                <button id="NF-enabled" name="NF-enabled" authorize="yes" class="layui-btn layui-btn-sm data-enabled-btn layui-hide" lay-event="enabled"> <i class="fa fa-play-circle"></i>启用</button>
                <button id="NF-disabled" name="NF-disabled" authorize="yes" class="layui-btn layui-btn-sm layui-btn-danger data-disabled-btn layui-hide" lay-event="disabled"><i class="fa fa-stop-circle"></i>终止</button>
                <button id="NF-print" name="NF-print" authorize class="layui-btn layui-btn-sm layui-hide" lay-event="print"> <i class="layui-icon">&#xe66d;</i>打印</button>
            </div>
        </script>
        <table class="layui-hide" id="currentTableId" lay-filter="currentTableFilter"></table>
        <script type="text/html" id="currentTableBar">
            <a id="NF-edit" authorize class="layui-btn layui-btn-sm" lay-event="edit"><i class="layui-icon">&#xe642;</i></a>
            <a id="NF-delete" authorize class="layui-btn layui-btn-sm layui-btn-danger data-delete-btn" lay-event="delete"><i class="layui-icon">&#xe640;</i></a>
            <a id="NF-enabled" authorize class="layui-btn layui-btn-sm" lay-event="enabled"><i class="fa fa-play-circle"></i></a>
            <a id="NF-disabled" authorize class="layui-btn layui-btn-sm layui-btn-danger" lay-event="disabled"><i class="fa fa-stop-circle"></i></a>
        </script>
    </div>
</div>
<script>
    layui.use(['jquery', 'form', 'table', 'commonTable', 'common', 'optimizeSelectOption'], function () {
        var $ = layui.jquery,
            form = layui.form,
            table = layui.table, commonTable = layui.commonTable
        common = layui.common;
        //权限控制(js是值传递)
        currentTableBar.innerHTML = common.authorizeButtonNew(currentTableBar.innerHTML);
        toolbarDemo.innerHTML = common.authorizeButtonNew(toolbarDemo.innerHTML);
        commonTable.rendertable({
            elem: '#currentTableId',
            id: 'currentTableId',
            url: '/MaterialManage/InStorage/GetGridJson',
            cols: [[
                //此处需修改
                { type: "checkbox", width: 50 },
                { field: 'F_InStorageCode', title: '入库单编号', width: 180, sort: true, filter: true },
                {
                    field: 'F_InStorageState', title: '入库单状态', width: 120, sort: true, filter: true,
                    templet: function (d) {
                        if (d.F_InStorageState == 0) {
                            return "<span class='layui-btn layui-btn-normal layui-btn-xs'>等待中</span>";
                        }
                        if (d.F_InStorageState == 1) {
                            return "<span class='layui-btn layui-btn-warm layui-btn-xs'>执行中</span>";
                        }
                        if (d.F_InStorageState == 2) {
                            return "<span class='layui-btn layui-btn-xs'>已绑定</span>";
                        }
                        if (d.F_InStorageState == 3) {
                            return "<span class='layui-btn layui-btn-danger layui-btn-xs'>已终止</span>";
                        }
                        if (d.F_InStorageState == 4) {
                            return "<span class='layui-btn layui-btn-danger layui-btn-xs'>已完成</span>";
                        }
                    }
                },
                {
                    field: 'F_MaterialType', title: '料号分类', width: 105, sort: true, filter: true,
                    templet: function (d) {
                        return top.clients.dataItems["Mes_MaterialType"][d.F_MaterialType] == null ? "" : top.clients.dataItems["Mes_MaterialType"][d.F_MaterialType];
                    }
                },
                { field: 'F_MaterialCode', title: '料号编号', width: 170, sort: true, filter: true },
                { field: 'F_MaterialName', title: '料号名称', width: 200, sort: true, filter: true },
                { field: 'F_MaterialUnit', title: '料号单位', width: 120, sort: true, filter: true },
                { field: 'F_PlanTime', title: '计划时间', width: 160, sort: true, filter: { type: 'date[yyyy/MM/dd HH:mm:ss]' } },
                { field: 'F_CarNo', title: '车辆', width: 140, sort: true, filter: true },
                { field: 'F_Num', title: '数量', width: 80, sort: true, filter: true },
                { field: 'F_DoneNum', title: '完成数量', width: 105, sort: true, filter: true },
                { field: 'F_BadNum', title: '不良数量', width: 105, sort: true, filter: true },
                {
                    field: 'F_EnabledMark', title: '状态', width: 80, sort: true, filter: true,
                    templet: function (d) {
                        if (d.F_EnabledMark == true) {
                            return "<span class='layui-btn layui-btn-normal layui-btn-xs'>有效</span>";
                        } else {
                            return "<span class='layui-btn layui-btn-warm layui-btn-xs'>无效</span>";
                        }
                    }
                },
                {
                    field: 'F_CreatorTime', title: '创建时间', width: 160, sort: true, filter: { type: 'date[yyyy/MM/dd HH:mm:ss]' }
                },
                { field: 'F_Description', title: '备注', minWidth: 120, sort: true, filter: true },

                { title: '操作', width: 210, toolbar: '#currentTableBar', align: "center" }
            ]]
        });
        // 监听搜索操作
        form.on('submit(data-search-btn)', function (data) {
            //执行搜索重载
            commonTable.reloadtable({
                elem: 'currentTableId',
                curr: 1,
                where: { keyword: data.field.txt_keyword }
            });
            return false;
        });
        wcLoading.close();
        //行点击事件监听，控制按钮显示
        var oneList = ["NF-edit", "NF-details", "NF-enabled", "NF-disabled"];//选择1条显示
        var morerList = ["NF-delete", "NF-print"];//选中1条以上显示
        commonTable.tableRowClick("checkbox", "currentTableFilter", "currentTableId", oneList, morerList);
        //toolbar监听事件
        table.on('toolbar(currentTableFilter)', function (obj) {
            var data = table.checkStatus('currentTableId').data;
            if (obj.event === 'add') {  // 监听添加操作
                common.modalOpen({
                    title: "添加入库单",
                    url: "/MaterialManage/InStorage/Form",
                    width: "450px",
                    height: "450px",
                });
            }
            else if (obj.event === 'delete') {
                if (data.length == 0) {
                    common.modalMsg("未选中数据", "warning");
                    return false;
                }
                var ids = [];
                for (var i = 0; i < data.length; i++) {
                    ids.push(data[i].F_Id);
                }
                common.deleteForm({
                    url: "/MaterialManage/InStorage/DeleteForm",
                    param: { keyValue: ids.join(',') },
                    success: function () {
                        common.reload('data-search-btn');
                    }
                });
            }
            else if (obj.event === 'edit') {
                if (data.length == 0) {
                    common.modalMsg("未选中数据", "warning");
                    return false;
                }
                common.modalOpen({
                    title: "编辑入库单",
                    url: "/MaterialManage/InStorage/Form?keyValue=" + data[0].F_Id,
                    width: "450px",
                    height: "450px",
                });
            }
            else if (obj.event === 'details') {
                if (data.length == 0) {
                    common.modalMsg("未选中数据", "warning");
                    return false;
                }
                common.modalOpen({
                    title: "查看界面",
                    url: "/MaterialManage/InStorage/Details?keyValue=" + data[0].F_Id,
                    width: "780px",
                    height: "650px",
                    btn: []
                });
            }
            else if (obj.event === 'enabled') {
                common.submitPost({
                    prompt: "注：您确定要【启动】该项单据吗？",
                    url: "/MaterialManage/InStorage/EnabledForm",
                    param: { keyValue: data[0].F_Id },
                    success: function () {
                        common.reload('data-search-btn');
                    }
                });
            }
            else if (obj.event === 'disabled') {
                common.submitPost({
                    prompt: "注：您确定要【终止】该项单据吗？",
                    url: "/MaterialManage/InStorage/DisabledForm",
                    param: { keyValue: data[0].F_Id },
                    success: function () {
                        common.reload('data-search-btn');
                    }
                });
            }
            else if (obj.event === 'print') {
                if (data.length == 0) {
                    common.modalMsg("未选中数据", "warning");
                    return false;
                }
                if (top.websocket == null || top.websocket.readyState == 3) {
                    common.modalMsg("打印服务未开启", "warning");
                    return false;
                }
                common.modalConfirm("注：您确定要打印选中这些数据吗？", function (r) {
                    if (r) {
                        var ids = [];
                        var json = {};
                        json.cmd = "print";
                        json.requestId = uuid();
                        json.data = {};
                        json.data.printIniInfo = {};
                        json.data.printIniInfo.filePath = window.document.location.origin + top.clients.printTemplates["出入库单据模板"];
                        json.data.printIniInfo.realName = "出入库单据模板";
                        json.data.printIniInfo.printType = 1;
                        json.data.printIniInfo.printName = "";
                        json.data.printIniInfo.landscape = true;
                        json.data.printIniInfo.paperSize = "";
                        json.data.printIniInfo.duplex = "";
                        json.data.data = [];
                        for (var i = 0; i < data.length; i++) {
                            var listData = JSON.parse(data[i].F_BatchJson);
                            for (var j = 0; j < listData.length; j++) {
                                var temp = {};
                                temp.barId = listData[j].F_MaterialBatch;
                                temp.code = listData[j].F_MaterialBatch;
                                temp.name = listData[j].F_MaterialName;
                                temp.num = listData[j].F_Num;
                                json.data.data.push(temp);
                            }
                        }
                        top.sendWSPush(json);
                    }
                });
            }
            else if (obj.event === 'TABLE_SEARCH') {
                var _that = $("#searchField");
                if (_that.hasClass("layui-hide")) {
                    _that.removeClass('layui-hide');
                } else {
                    _that.addClass('layui-hide');
                }
            }
            return false;
        });
        //toolrow监听事件
        table.on('tool(currentTableFilter)', function (obj) {
            if (obj.event === 'delete') {
                common.deleteForm({
                    url: "/MaterialManage/InStorage/DeleteForm",
                    param: { keyValue: obj.data.F_Id },
                    success: function () {
                        obj.del();
                    }
                });
            }
            else if (obj.event === 'edit') {
                common.modalOpen({
                    title: "编辑入库单",
                    url: "/MaterialManage/InStorage/Form?keyValue=" + obj.data.F_Id,
                    width: "450px",
                    height: "450px",
                });
            }
            else if (obj.event === 'enabled') {
                common.submitPost({
                    prompt: "注：您确定要【启动】该项单据吗？",
                    url: "/MaterialManage/InStorage/EnabledForm",
                    param: { keyValue: obj.data.F_Id },
                    success: function () {
                        common.reload('data-search-btn');
                    }
                });
            }
            else if (obj.event === 'disabled') {
                common.submitPost({
                    prompt: "注：您确定要【终止】该项单据吗？",
                    url: "/MaterialManage/InStorage/DisabledForm",
                    param: { keyValue: obj.data.F_Id },
                    success: function () {
                        common.reload('data-search-btn');
                    }
                });
            }
            return false;
        });
    });
</script>
